





3/64
NS | S
Monitor | 86









Fig. 9









Fig. 13A



Fig. 12



Fig. 13B

| Exception      | Vector offs | et Corresponding mode       |
|----------------|-------------|-----------------------------|
| Reset          | 0x00        | Supervisor mode             |
| Under          | 0x04        | Monitor mode / Unles ~~ le  |
| SWI            | 0x08        | Supervisor mode Monter make |
| Prefetch abort | 0x0C        | Abort mode Monitor mode     |
| Data abort     | 0x10        | Abort mode / Mon: for mode  |
| IRQ/SIRQ       | 0x18        | IRQ mode Mon: for myde      |
| FIQ            | 0x1C        | FIQ mode Monitor made       |
| SMI            | OX 20       | appropriate marganita       |

F1214

| Reset          | VMO |
|----------------|-----|
| Winder         | VMI |
| SWI            | VM2 |
| Prefetch about | VM3 |
| Data abort     | VM4 |
| IRQ/SIRQ       | VMS |
| FIQ            | 7W6 |
| SMI            | VM7 |

| Reset          | VSØ        |
|----------------|------------|
| World          | VSI        |
| SWI            | VS2.       |
| ProJetch about | <b>VS3</b> |
| Data abort     | VSY        |
| IRQ/SIRQ       | <b>755</b> |
| FIQ            | VS6        |
| SMI            | VS7        |

| Reiset          | VNSØ    |
|-----------------|---------|
| Wool            | VNSI    |
| SWI             | VNS2    |
| Protetely about | VN53    |
| Data about      | VN54    |
| IRQ/SIRQ        | VNSS    |
| FIQ             | ** VNS6 |
| SMI             | VN57    |

Fig. 15.

CP15 Monitor Trap Mask Register

|     | 1   | . \               | ١             | . 1 | 0    | 1_  |
|-----|-----|-------------------|---------------|-----|------|-----|
| SMI | SWI | Protetch<br>Abort | Oata<br>Abort | IRQ | SIRQ | FIQ |

1 = Mon(S)

OR via hardware/external

Fig. 16.











FIGURE 21

| User | System | Supervisor | Abort     | Undefined | Interrupt | Fast Interrupt |
|------|--------|------------|-----------|-----------|-----------|----------------|
| R0   | R0     | R0         | R0        | R0        | R0        | R0             |
| R1   | R1     | R1         | R1        | R1        | R1        | R1             |
| R2   | R2     | R2         | R2        | R2        | R2        | R2             |
| R3   | R3     | R3         | R3        | R3        | R3        | R3             |
| R4   | R4     | R4         | R4        | R4        | R4        | R4             |
| R5   | R5     | R5         | R5        | R5        | R5        | R5             |
| R6   | R6     | R6         | R6        | R6        | R6        | R6             |
| R7   | R7     | R7         | R7        | R7        | R7        | R7             |
| R8   | R8     | R8         | R8        | R8        | R8        | R8_fiq         |
| R9   | R9     | R9         | R9        | R9        | R9        | R9_fiq         |
| R10  | R10    | R10        | R10       | R10       | R10       | R10_fiq        |
| R11  | R11    | R11        | R11       | R11       | R11       | R11_fiq        |
| R12  | R12    | R12        | R12       | R12       | R12       | R12_fiq        |
| R13  | R13    | R13_54C    | R13 abl ' | R13_und   | R13_irq   | R13_fiq        |
| R14  | R14    | THY SVE    | R'M_sbt/  | R14_und   | R14_irq   | R14_fiq .      |
| PC   | PC     | PC         | PC        | PC        | PC        | PC             |

| Monitor |   |
|---------|---|
| R0      | _ |
| R1      |   |
| R2      |   |
| R3      |   |
| R4      |   |
| R5      |   |
| R6      |   |
| R7      |   |
| R8      |   |
| R9      |   |
| R10     |   |
| R11     |   |
| R12     |   |
| R13_mon | J |
| R14_mon |   |
| PC      | J |
|         |   |

| CPSR  | CPSR  | CPSR     | CPSR     | CPSR     | CPSR     | CPSR     |
|-------|-------|----------|----------|----------|----------|----------|
| Croix | 10.01 | SPSR svc | SPSR abt | SPSR_und | SPSR irq | SPSR_fiq |
|       | 1     | 0.0.1    |          |          |          |          |

CPSR SPSR\_mon

FIGURE 22



FIGURE 23

ARM

5 = 1

1-1g. 24



1-ig. 25



fig. 26









Fig. 30

4012 Call received 4014 call Y 8 اصا 4016 new thread available? 4020 active secure Leject call

Fig. 31

26/64 Monitor Non-Secure Int 2 hardler NSB

Lig. 32

Monitor Secure

SA

VEN Int 1 Non-secure Int 2 | hardler Rosume | Stub Int] hadler Close Stub Int1 / houdler > Rosume | SA

Fig 33



F16.35



FIG. 36



FIG. 37



FIG. 38





F16.40



F16-41



FIG. 42





F16.44



FIG. 45



FIG. 46





Fig. 48





PHYSICAL BOOKESS SAACE

F16. 49



FIG SOA



FIG SOB



F16 51



FIG 52







FIG 55



FIG 56



FIG 57



FIG 58

|                                 | How to program?                                                 | How to enter?                                                                                                                                    | Entry mode   |
|---------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| Dioanponi                       | Debug TAP or                                                    | Program breakpoint register and/or context-ID register and comparisons succeed with Instruction Address and/or CP15 Context ID (²).              | Halt/monitor |
| Software breakpoint instruction | Register) through Debug TAP or Use BKPT instruction directly in | BKPT instruction must reach execution stage.                                                                                                     | Halt/monito  |
| Vector trap breakpoint          | the code.  Debug TAP                                            | Program vector trap register and address matches.                                                                                                | Halt/monito  |
| Watchpoint hits                 | Debug TAP<br>or software (CP14)                                 | Program watchpoint register and/or context-ID register and comparisons succeed with Instruction Address and/or CP15 Context ID ( <sup>2</sup> ). | Halt/monito  |
| - Lill - compat                 | Debug TAP                                                       | Halt instruction has been scanned in.                                                                                                            | Halt         |
| Internal debug request          | Not applicable                                                  | EDBGRQ input pin is asserted.                                                                                                                    | Halt         |

(1): In monitor mode, breakpoints and watchpoints cannot be data-dependent.

<sup>(2):</sup> The cores have support for thread-aware breakpoints and watchpoints in order to aloue, to enable secure debug on some particular threads.

56/64

| Name                                 | Meaning                                                                                            | Reset<br>value | Access                                                                                                                                                                                                                                                 | Inserted in scan chain for test |
|--------------------------------------|----------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Monitor<br>mode enable<br>bit        | 0: halt mode<br>1: monitor mode                                                                    | 1              | R/W by programming the ICE by the JTAG (scan1)  R/W by using MRC/MCR instruction (CP14)                                                                                                                                                                | yes                             |
| Secure debug<br>enable bit           | 0: debug in non-<br>secure world only.<br>1: debug in secure<br>world and non-<br>secure world     | 0              | In functional mode or debug monitor mode: R/W by using MRC/MCR instruction (CP14) (only in secure supervisor mode)  In Debug halt mode: No access – MCR/MRC instructions have any effect.  (R/W by programming the ICE by the JTAG (scan1) if JSDAEN=1 | no                              |
| Secure trace enable bit              | 0: ETM is enabled in non-secure world only. 1: ETM is enabled in secure world and non-secure world | 0              | In functional mode or debug monitor mode: R/W by using MRC/MCR instruction (CP14) (only in secure supervisor mode)  In Debug halt mode: No access – MCR/MRC instructions have any effect.  (R/W by programming the ICE by the JTAG (scan1) if JSDAEN=1 | no                              |
| Secure user-<br>mode enable<br>bit   | 0: debug is not possible in secure user mode 1: debug is possible in secure user mode              | 1              | In functional mode or debug monitor mode: R/W by using MRC/MCR instruction (CP14) (only in secure supervisor mode)  In Debug halt mode: No access – MCR/MRC instructions have any effect.  (R/W by programming the ICE by the JTAG (scan1) if JSDAEN=1 | no                              |
| Secure<br>thread-aware<br>enable bit | 0: debug is not possible for a particular thread 1: debug is possible for a particular thread      | 0              | In functional mode or debug monitor mode: R/W by using MRC/MCR instruction (CP14) (only in secure supervisor mode)  In Debug halt mode: No access – MCR/MRC instructions have any effect.  (R/W by programming the ICE by the JTAG (scan1) if JSDAEN=1 | no                              |

Figure 6/

## 57/64

**Function Table** 

| D | CK | Q[n+1] |
|---|----|--------|
| 0 |    | 0      |
| 1 |    | 1      |
| х | /  | Q[n]   |

Logic Symbol



FIGURE 62

**Function Table** 

| D <sub>.</sub> | SI | SE | CK | Q[n+1] |
|----------------|----|----|----|--------|
| 0              | x  | 0  |    | 0      |
| 1              | x  | 0  |    | 1      |
| X              | X  | X  |    | Q[n]   |
| X              | 0  | 1  |    | 0      |
| X              | 1  | 1  |    | 1      |

Logic Symbol





FIGURE 64



Figure 65.



FIGURE 66A



FIGURE 66 B



Figure 67



Figure 68

| CP14 bits in Debug and Status Control register |                                   | ontrol register                      | meaning                                                                                                                                                                                                                                              |  |
|------------------------------------------------|-----------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Secure debug enable<br>bit                     | Secure user-mode debug enable bit | Secure thread-aware debug enable bit |                                                                                                                                                                                                                                                      |  |
| 0                                              | х                                 | X                                    | No intrusive debug in entire secure world is possible.<br>Any debug request, breakpoints, watchpoints, and other<br>mechanism to enter debug state are ignored in entire<br>secure world.                                                            |  |
| 1                                              | 0                                 | X                                    | Debug in entire secure world is possible                                                                                                                                                                                                             |  |
| 1                                              | 1                                 | 0                                    | Debug in secure user-mode only. Any debug request, breakpoints, watchpoints, and other mechanism to enter                                                                                                                                            |  |
|                                                |                                   |                                      | debug state are taken into account in user mode only. (Breakpoints and watchpoints linked or not to a thread ID are taken into account). Access in debug is restricted                                                                               |  |
|                                                |                                   | <u> </u>                             | to what secure user can have access to.                                                                                                                                                                                                              |  |
| 1                                              | 1                                 | 1                                    | Debug is possible only in some particular threads. In that case only thread-aware breakpoints and watchpoints linked to a thread ID are taken into account to enter debug state. Each thread can moreover debug its own code, and only its own code. |  |

## Figure 69A

| CP14 bits in Debug and Status Control register |                                   | meaning                              |                                                                                                                                                          |
|------------------------------------------------|-----------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Secure trace enable bit                        | Secure user-mode debug enable bit | Secure thread-aware debug enable bit |                                                                                                                                                          |
| Oit                                            | X                                 | X                                    | No observable debug in entire secure world is possible.                                                                                                  |
| U                                              | 1                                 | ·                                    | Trace module (ETM) must not trace internal core                                                                                                          |
|                                                |                                   |                                      | activity.                                                                                                                                                |
| <u>. The first of the strain of the </u>       |                                   | X                                    | Trace in entire secure world is possible                                                                                                                 |
| 1                                              | 1                                 | 0                                    | Trace is possible when the core is in secure user-mode                                                                                                   |
| . •                                            |                                   |                                      | only.                                                                                                                                                    |
| <u> </u>                                       | 1                                 | 1                                    | Trace is possible only when the core is executing some particular threads in secure user mode. Particular hardware must be dedicated for this, or re-use |
|                                                |                                   |                                      | breakpoint register pair: Context ID match must enable trace instead of entering debug state.                                                            |

Figure 69B

Program

A

B

A

B

A

| Method of entry                 | Entry when in non-secure world                                  | entry when in secure world                                                         |
|---------------------------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------|
| Breakpoint hits                 | Non-secure prefetch abort handler                               |                                                                                    |
| Software breakpoint instruction | Non-secure prefetch abort handler                               |                                                                                    |
| Vector trap breakpoint          | interruptions. For other non-secure exceptions, prefetch abort. | secure prefetch abort exceptions (1). For other exceptions, secure prefetch abort. |
| Watchpoint hits                 |                                                                 | secure data abort handler                                                          |
| Internal debug request          |                                                                 | debug state in halt mode                                                           |
| External debug request          | Debug state in halt mode                                        | debug state in halt mode                                                           |

- (1) see in Comation on vector trap register,:
- (2) Note that when external or internal debug request is asserted, the core enters halt mode and not monitor mode.

## Figure 71A

| Method of entry                         | Entry in non-secure world                                                                    | entry in secure world           |
|-----------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------|
| Breakpoint hits                         | Non-secure prefetch abort handler                                                            | breakpoint ignored :            |
| Software breakpoint instruction         | Non-secure prefetch abort handler                                                            | instruction ignored (-) as 28   |
| Vector trap breakpoint                  | non-secure prefetch abort interruptions.  For others interruption non-secure prefetch abort. |                                 |
| Watchpoint hits                         | Non-secure data abort handler                                                                | watchpoint ignored.             |
| Internal debug request                  |                                                                                              | request ignored to the state of |
| External debug request                  |                                                                                              | request ignored                 |
| Debug re-entry from system speed access | not applicable                                                                               | notapplicable a                 |

(¹) As substitution of BKPT instruction in secure world from non-secure world is not possible, non-secure abort must handle the violation.